﻿Imports DTO
Imports DAO
Imports BUS

Public Class frmCapNhatBangTheLoaiSach : Inherits DevComponents.DotNetBar.Office2007Form

    ' Hàm reset
    Private Sub Reset()
        'txtTenBangCap.Text = ""
        txtMaTheLoai.Text = ""
        txtTenTheLoaiMoi.Text = ""
    End Sub

    ' Hàm kiểm tra dữ liệu khi thêm
    Private Function KiemTraDuLieuThem() As Boolean
        Return txtTenTheLoai.Text <> ""
    End Function

    ' Khi nhấn nút Thoát
    Private Sub btnThoat_Click(ByVal sender As System.Object, ByVal e As System.EventArgs)
        Me.Close()
    End Sub

    ' Hàm thực hiện thêm bằng cấp
    Private Sub btnThem_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnThem.Click
        If KiemTraDuLieuThem() Then
            Dim kt As Integer = New CTheLoaiSachBUS().ThemTheLoaiSach(txtTenTheLoai.Text)
            If (kt = (-1)) Then
                MessageBox.Show("Số thể loại sách không thể vượt quá số lượng quy định", "Thong Bao")
                txtTenTheLoai.Text = ""
                Return
            Else
                If (kt = 0) Then
                    MessageBox.Show("Tên thể loại này đã tồn tại này đã tồn tại!", "Thong Bao")
                    txtTenTheLoai.Text = ""
                    Return
                Else
                    MessageBox.Show("Đã thêm thành công!", "Thong Bao")
                    txtTenTheLoai.Text = ""
                    Dim listtheloaisach As List(Of CTheLoaiSachDTO) = New CTheLoaiSachBUS().LayDanhSachTheLoaiSach()
                    dgvTheLoaiSach.Rows.Clear()
                    stt = 1
                    For Each theloaisach As CTheLoaiSachDTO In listtheloaisach
                        dgvTheLoaiSach.Rows.Add(stt, theloaisach.Ma, theloaisach.Ten)
                        stt += 1
                    Next
                    Return
                End If
            End If
        Else
            MessageBox.Show("Dữ liệu không hợp lệ!", "Thong Bao")
            txtTenTheLoai.Focus()
            Return
        End If

    End Sub

    Private stt As Integer

    ' Hàm load
    Private Sub frmCapNhatBangTheLoaiSach_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
        stt = 1
        dtiNgayCapNhat.Value = DateTime.Now

        ' Load danh sách thể loại sách vào trong datagridview:
        Dim listtheloaisach As List(Of CTheLoaiSachDTO) = New CTheLoaiSachBUS().LayDanhSachTheLoaiSach()
        dgvTheLoaiSach.Rows.Clear()
        For Each theloaisach As CTheLoaiSachDTO In listtheloaisach
            dgvTheLoaiSach.Rows.Add(stt, theloaisach.Ma, theloaisach.Ten)
            stt += 1
        Next
    End Sub


    ' Xử lý khi chọn vào dòng nào trong datagridview thì ta load nó lên cập nhật:
    Private Sub dgvTheLoaiSach_CellClick(ByVal sender As System.Object, ByVal e As System.Windows.Forms.DataGridViewCellEventArgs) Handles dgvTheLoaiSach.CellClick
        Dim index As Integer = e.RowIndex
        If index < 0 Then
            If txtTenTheLoai.Text <> "" Then
                Reset()
            End If
            Return
        End If

        If (index >= dgvTheLoaiSach.Rows.Count) Then
            If (txtMaTheLoai.Text <> "") Then
                Reset()
            End If
            Return
        End If

        Dim dr As DataGridViewRow = dgvTheLoaiSach.Rows(index)
        txtMaTheLoai.Text = dr.Cells("clMaTheLoai").Value
        txtTenTheLoaiMoi.Text = dr.Cells("clTenTheLoai").Value

    End Sub


    Private Sub btnCapNhat_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnUpdate.Click
        Dim theloaisach As New CTheLoaiSachDTO()
        If (Not Integer.TryParse(txtMaTheLoai.Text, theloaisach.Ma)) Then
            MessageBox.Show("Cần chọn thể loại muốn cập nhật!", "Thong Bao")
            Return
        End If
        If (txtTenTheLoaiMoi.Text = "") Then
            MessageBox.Show("Cần nhập tên thể loại mới để cập nhật!", "Thong Bao")
            txtTenTheLoaiMoi.Focus()
            Return
        End If

        theloaisach.Ten = txtTenTheLoaiMoi.Text

        Dim theloaisachbus As New CTheLoaiSachBUS()
        Dim kq As Integer = theloaisachbus.CapNhatTheLoaiSach(theloaisach)
        If (kq = 0) Then
            MessageBox.Show("Tên thể loại này đã có", "Thong Bao")
            Return
        Else
            MessageBox.Show("Đã cập nhật thành công!", "Thong Bao")
            Reset()
            dgvTheLoaiSach.Rows.Clear()
            Dim listtheloaisach As List(Of CTheLoaiSachDTO) = New CTheLoaiSachBUS().LayDanhSachTheLoaiSach()
            stt = 1
            For Each tls As CTheLoaiSachDTO In listtheloaisach
                dgvTheLoaiSach.Rows.Add(stt, tls.Ma, tls.Ten)
                stt += 1
            Next
            Return
        End If
    End Sub

End Class